package com.eystar.ext.kit;

import cn.hutool.core.lang.Snowflake;
import cn.hutool.core.util.IdUtil;

/**
 * ID生成工具
 * 
 * @author auth
 * 
 */
public class UUIDKit {
	
	private static Snowflake sf = IdUtil.createSnowflake(1, 1);
	private static String[] chars = new String[] { "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z", "0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z" };

	/**
	 * 生成一个uuid
	 * @return
	 */
	public static synchronized String nextID() {
		return IdUtil.fastSimpleUUID();
	}
	
	/**
	 * 根据Twitter的Snowflake 算法，生成一个长整形ID
	 * @return
	 */
	public static synchronized long nexLongID() {  
		return sf.nextId(); 
	}
	
	/**
	 * <pre>
	 * 短8位UUID思想其实借鉴微博短域名的生成方式，但是其重复概率过高，
	 * 而且每次生成4个，需要随即选取一个。
	 * 本算法利用62个可打印字符，通过随机生成32位UUID，由于UUID都为十六进制，所以将UUID分成8组，
	 * 每4个为一组，然后通过模62操作，结果作为索引取出字符，这样重复率大大降低。
	 * <b>经测试，在生成一千万个数据也没有出现重复，完全满足大部分需求。</b>
	 * </pre>
	 * 生成短UUID
	 * @return
	 */
	public static synchronized String nextShortUUID() {
		StringBuffer shortBuffer = new StringBuffer();
		String uuid = nextID();
		for (int i = 0; i < 8; i++) {
			String str = uuid.substring(i * 4, i * 4 + 4);
			int x = Integer.parseInt(str, 16);
			shortBuffer.append(chars[x % 0x3E]);
		}
		return shortBuffer.toString();

	}
	
	public static void main(String[] args) {
		System.out.println(nextShortUUID());
	}
}
